<template>
  <div class="setting-container">
    <div class="app-container">
      <!-- 卡片组件 -->
      <el-card class="box-card">
        <!-- 使用 Tabs 组件完成标签页布局 -->
        <el-tabs v-model="activeName">
          <!-- 角色管理 -->
          <el-tab-pane
            label="角色管理"
            name="first"
            class="tab-pane"
          >
            <!-- 新增角色按钮 -->
            <el-row style="height:60px">
              <el-button
                icon="el-icon-plus"
                size="small"
                type="primary"
                @click="addRoleBtnFn"
              >新增角色</el-button>
            </el-row>
            <!-- 使用 Table 组件实现用户角色的渲染 -->
            <el-table
              border
              style="width: 100%"
              :data="rolesList"
            >
              <el-table-column
                type="index"
                label="序号"
                width="120"
                :index="(index) => (query.page - 1 ) * query.pagesize + index + 1"
              />
              <el-table-column
                label="角色名"
                prop="name"
                width="240"
              />
              <el-table-column
                label="描述"
                prop="description"
              />
              <el-table-column label="操作">
                <template slot-scope="scope">
                  <el-button
                    size="small"
                    type="success"
                    @click="setRoles(scope.row)"
                  >分配权限</el-button>
                  <el-button
                    size="small"
                    type="primary"
                    @click="editRoles(scope.row)"
                  >编辑</el-button>
                  <el-button
                    size="small"
                    type="danger"
                    @click="delRoles(scope.row)"
                  >删除</el-button>
                </template>
              </el-table-column>
            </el-table>

            <!-- 分页区域 -->
            <el-pagination
              :current-page="query.page"
              :page-sizes="[10, 15, 20, 25]"
              :page-size="query.pagesize"
              layout="total, sizes, prev, pager, next, jumper"
              :total="total"
              @size-change="handleSizeChange"
              @current-change="handleCurrentChange"
            />
          </el-tab-pane>

          <!-- 公司信息 -->
          <el-tab-pane
            label="公司信息"
            class="tab-pane"
          >
            <el-alert
              title="对公司名称、公司地址、营业执照、公司地区的更新，将使得公司资料被重新审核，请谨慎修改"
              type="info"
              show-icon
              :closable="false"
            />

            <el-form
              label-width="120px"
              style="margin-top:50px"
              :model="companyObj"
            >
              <el-form-item label="公司名称">
                <el-input
                  v-model="companyObj.name"
                  disabled
                  style="width:400px"
                />
              </el-form-item>
              <el-form-item label="公司地址">
                <el-input
                  v-model="companyObj.companyAddress"
                  disabled
                  style="width:400px"
                />
              </el-form-item>
              <el-form-item label="邮箱">
                <el-input
                  v-model="companyObj.mailbox"
                  disabled
                  style="width:400px"
                />
              </el-form-item>
              <el-form-item label="备注">
                <el-input
                  v-model="companyObj.remarks"
                  type="textarea"
                  :rows="3"
                  disabled
                  style="width:400px"
                />
              </el-form-item>
            </el-form>
          </el-tab-pane>
        </el-tabs>

      </el-card>

      <!-- 新增弹框 -->
      <el-dialog
        :title="isEdit ? '修改角色' : '新增角色'"
        :close-on-click-modal="false"
        :close-on-press-escape="false"
        :visible.sync="showDialog"
        @close="roleDialogCloseFn"
      >
        <el-form
          ref="roleForm"
          :model="roleForm"
          :rules="roleRules"
          label-width="100px"
        >
          <el-form-item
            label="角色名称"
            prop="name"
          >
            <el-input v-model="roleForm.name" />
          </el-form-item>
          <el-form-item
            label="角色描述"
            prop="description"
          >
            <el-input v-model="roleForm.description" />
          </el-form-item>
        </el-form>

        <!-- 底部 -->
        <el-row
          slot="footer"
          type="flex"
          justify="center"
        >
          <el-col :span="6">
            <el-button
              size="small"
              @click="cancleRoles"
            >取消</el-button>
            <el-button
              size="small"
              type="primary"
              @click="roleSubmit"
            >确定</el-button>
          </el-col>
        </el-row>

      </el-dialog>
    </div>
  </div>
</template>

<script>
import {
  addRolesAPI,
  deleteRolesAPI,
  getCompanyInfoAPI,
  getProfileAPI,
  getRoleInfoAPI,
  getRoleListAPI,
  updateRolesAPI
} from '@/api'
export default {
  data() {
    return {
      activeName: 'first',
      query: {
        page: 1, // 当前页面
        pagesize: 10 // 页面显示的条数
      },
      rolesList: [], // 角色列表
      total: 0, // 角色数据总条数
      companyObj: {}, // 公司信息对象
      showDialog: false, // 控制弹框的隐藏和展示
      // 添加角色
      roleForm: {
        name: '',
        description: ''
      },
      // 添加角色验证
      roleRules: {
        name: [
          { required: true, message: '角色名称不能为空', trigger: 'blur' }
        ],
        description: [
          { required: true, message: '角色描述不能为空', trigger: 'blur' }
        ]
      },
      isEdit: false // 是否处于编辑状态
    }
  },
  created() {
    this.getRoleListFn() // 获取角色列表
    this.getCompanyInfoFn() // 获取公司信息
  },
  methods: {
    // 每页显示的条数发生改变时触发
    handleSizeChange(newSize) {
      this.query.pagesize = newSize
      this.getRoleListFn()
    },

    // 当前页面发生改变时触发
    handleCurrentChange(newSize) {
      this.query.page = newSize
      this.getRoleListFn()
    },

    // 设置角色
    setRoles() {},

    // 编辑角色
    async editRoles(roleObj) {
      const res = await getRoleInfoAPI(roleObj.id)
      if (!res.success) return this.$message.error(res.message)
      this.roleForm = res.data

      this.isEdit = true
      this.showDialog = true
    },

    // 删除角色
    async delRoles(roleObj) {
      // 显示删除询问对话框
      const delRes = await this.$confirm(
        '此操作将永久删除该角色, 是否继续?',
        '提示',
        {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        }
      ).catch((err) => err)

      // 用户点击了取消，给用户进行提示
      if (delRes === 'cancel') return this.$message.info('您取消了删除')

      const res = await deleteRolesAPI(roleObj.id)
      if (!res.success) return this.$message.error(res.message)

      // 刷新数据
      this.getRoleListFn()
      // 关闭弹窗
      this.showDialog = false
    },

    // 获取角色列表 -> 发送请求
    async getRoleListFn() {
      const { data: res } = await getRoleListAPI(this.query)
      this.rolesList = res.rows
      this.total = res.total
    },

    // 获取公司信息 -> 根据公司ID -> 发起请求
    async getCompanyInfoFn() {
      const res = await getCompanyInfoAPI(
        (
          await getProfileAPI()
        ).data.companyId
      )
      if (!res.success) return this.$message.error(res.message)
      this.companyObj = res.data
    },

    // 角色弹框-> 确定按钮
    roleSubmit() {
      this.$refs.roleForm.validate(async(valid) => {
        if (valid) {
          let res
          if (this.isEdit) res = await updateRolesAPI(this.roleForm)
          else res = await addRolesAPI()

          if (!res.success) return this.$message.error(res.message)
          this.$message.success(res.message)

          // 判断当前数据的长度是否等于 1
          if (this.rolesList.length === 1) {
            this.query.page--
            // 如果是第一页的第一条
            if (this.query.page === 0) {
              this.query.page = 1
            }
          }

          // 刷新数据
          this.getRoleListFn()
          // 关闭弹窗
          this.showDialog = false
        } else return
      })
    },

    // 角色弹框-> 取消按钮
    cancleRoles() {
      this.showDialog = false
    },

    // 新增角色按钮 -> 点击事件
    addRoleBtnFn() {
      this.isEdit = false
      this.showDialog = true
    },

    // 角色弹窗 -> 关闭的回调
    roleDialogCloseFn() {
      this.$refs.roleForm.resetFields()
      this.roleForm = this.$options.data()
    }
  }
}
</script>

<style lang="scss" scoped>
.box-card {
  padding: 10px 30px;
}

.tab-pane {
  padding: 20px;
}

.el-pagination {
  text-align: center;
  margin-top: 20px;
}
</style>
